<!DOCTYPE html>


  <html class="dark page-post">


<head><meta name="generator" content="Hexo 3.9.0">
  <meta charset="utf-8">
  
  <title>Vim使用摘要笔记 | Poetry&#39;s Blog</title>

  <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">

  
    <meta name="keywords" content="Vim,">
  

  <meta name="description" content="插入模式和退出VIM的方法VIM 具有 6 种基本模式和 5 种派生模式。">
<meta name="keywords" content="Vim">
<meta property="og:type" content="article">
<meta property="og:title" content="Vim使用摘要笔记">
<meta property="og:url" content="http://blog.poetries.top/2016/03/19/Vim使用摘要笔记/index.html">
<meta property="og:site_name" content="Poetry&#39;s Blog">
<meta property="og:description" content="插入模式和退出VIM的方法VIM 具有 6 种基本模式和 5 种派生模式。">
<meta property="og:locale" content="zh-Hans">
<meta property="og:image" content="http://7xq6al.com1.z0.glb.clouddn.com/vim-1.png">
<meta property="og:image" content="http://7xq6al.com1.z0.glb.clouddn.com/vim-2.png">
<meta property="og:image" content="http://7xq6al.com1.z0.glb.clouddn.com/vim-3.png">
<meta property="og:image" content="http://7xq6al.com1.z0.glb.clouddn.com/vim-4.png">
<meta property="og:image" content="http://7xq6al.com1.z0.glb.clouddn.com/vim-5.png">
<meta property="og:image" content="http://7xq6al.com1.z0.glb.clouddn.com/vim-6.png">
<meta property="og:image" content="http://xxx.fishc.com/forum/201510/29/232631xzmv2mjpv9ii4vao.png">
<meta property="og:image" content="http://xxx.fishc.com/forum/201511/06/162556ihjb5obhtgf5s6jm.png">
<meta property="og:image" content="http://7xq6al.com1.z0.glb.clouddn.com/vim-7.png">
<meta property="og:image" content="https://github.com/ma6174/vim/raw/master/screenshot.png">
<meta property="og:image" content="http://7xq6al.com1.z0.glb.clouddn.com/%E5%85%A5%E9%97%A8%E7%89%88--vim.png">
<meta property="og:image" content="http://7xq6al.com1.z0.glb.clouddn.com/%E7%BB%8F%E5%85%B8%E7%89%88--vim.gif">
<meta property="og:image" content="http://7xq6al.com1.z0.glb.clouddn.com/%E8%BF%9B%E9%98%B6%E7%89%88--vim.png">
<meta property="og:image" content="http://7xq6al.com1.z0.glb.clouddn.com/%E5%A2%9E%E5%BC%BA%E7%89%88--vim.png">
<meta property="og:updated_time" content="2020-08-15T04:25:31.902Z">
<meta name="twitter:card" content="summary">
<meta name="twitter:title" content="Vim使用摘要笔记">
<meta name="twitter:description" content="插入模式和退出VIM的方法VIM 具有 6 种基本模式和 5 种派生模式。">
<meta name="twitter:image" content="http://7xq6al.com1.z0.glb.clouddn.com/vim-1.png">

  

  
    <link rel="icon" href="/favicon.ico">
  

  <link href="/css/styles.css?v=c114cbeddx" rel="stylesheet">
<link href="/css/other.css?v=c114cbeddx" rel="stylesheet">


  
    <link rel="stylesheet" href="/css/personal-style.css">
  

  

  
  <script type="text/javascript">
    var _hmt = _hmt || [];
    (function() {
      var hm = document.createElement("script");
      hm.src = "//hm.baidu.com/hm.js?40b1f89aa80f2527b3db779c6898c879";
      var s = document.getElementsByTagName("script")[0];
      s.parentNode.insertBefore(hm, s);
    })();
  </script>


  
  <script type="text/javascript">
	(function(){
	    var bp = document.createElement('script');
	    var curProtocol = window.location.protocol.split(':')[0];
	    if (curProtocol === 'https') {
	        bp.src = 'https://zz.bdstatic.com/linksubmit/push.js';        
	    }
	    else {
	        bp.src = 'http://push.zhanzhang.baidu.com/push.js';
	    }
	    var s = document.getElementsByTagName("script")[0];
	    s.parentNode.insertBefore(bp, s);
	})();
  </script>



  
    <script async src="https://busuanzi.ibruce.info/busuanzi/2.3/busuanzi.pure.mini.js"></script>
    <link rel="stylesheet" href="//cdn.bootcss.com/font-awesome/4.3.0/css/font-awesome.min.css">
  

  <!-- 聊天系统 -->
  
    
   <link type="text/css" rel="stylesheet" href="/renxi/default.css">
   <style>
      #modal {
        position: static !important;
      }
      .filter {
        width: 100%;
        height: 100%;
        position: absolute;
        top: 0;
        left: 0;
        background: #fe5757;
        animation: colorChange 30s ease-in-out infinite;
        animation-fill-mode: both;
        mix-blend-mode: overlay;
      }
  
      @keyframes colorChange {
        0%, 100% {
            opacity: 0;
        }
        50% {
            opacity: .9;
        }
      }
   </style>
</head>
</html>
<body>
  
  
    <span id="toolbox-mobile" class="toolbox-mobile">导航</span>
  

  <div class="post-header CENTER">
   
  <div class="toolbox">
    <a class="toolbox-entry" href="/">
      <span class="toolbox-entry-text">导航</span>
      <i class="icon-angle-down"></i>
      <i class="icon-home"></i>
    </a>
    <ul class="list-toolbox">
      
        <li class="item-toolbox">
          <a
            class="CIRCLE"
            href="/archives/"
            rel="noopener noreferrer"
            target="_self"
            >
            博客
          </a>
        </li>
      
        <li class="item-toolbox">
          <a
            class="CIRCLE"
            href="/categories/"
            rel="noopener noreferrer"
            target="_self"
            >
            分类
          </a>
        </li>
      
        <li class="item-toolbox">
          <a
            class="CIRCLE"
            href="/tags/"
            rel="noopener noreferrer"
            target="_self"
            >
            标签
          </a>
        </li>
      
        <li class="item-toolbox">
          <a
            class="CIRCLE"
            href="/search/"
            rel="noopener noreferrer"
            target="_self"
            >
            搜索
          </a>
        </li>
      
        <li class="item-toolbox">
          <a
            class="CIRCLE"
            href="/link/"
            rel="noopener noreferrer"
            target="_self"
            >
            友链
          </a>
        </li>
      
        <li class="item-toolbox">
          <a
            class="CIRCLE"
            href="/about/"
            rel="noopener noreferrer"
            target="_self"
            >
            关于
          </a>
        </li>
      
    </ul>
  </div>


</div>


  <div id="toc" class="toc-article">
    <strong class="toc-title">文章目录<i class="iconfont toc-title" style="display:inline-block;color:#87998d;width:20px;height:20px;">&#xf004b;</i></strong>
    <ol class="toc"><li class="toc-item toc-level-3"><a class="toc-link" href="#插入模式和退出VIM的方法"><span class="toc-text">插入模式和退出VIM的方法</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#删除命令、数字的奥义、撤销和恢复命令"><span class="toc-text">删除命令、数字的奥义、撤销和恢复命令</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#粘贴命令、替换命令、替换模式和修改命令"><span class="toc-text">粘贴命令、替换命令、替换模式和修改命令</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#文件信息、跳转、定位括号和缩进"><span class="toc-text">文件信息、跳转、定位括号和缩进</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#搜索命令和替换命令"><span class="toc-text">搜索命令和替换命令</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#执行shell命令、文件另存为、合并文件和打开多个文件"><span class="toc-text">执行shell命令、文件另存为、合并文件和打开多个文件</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#其他总结"><span class="toc-text">其他总结</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#vim-使用tip"><span class="toc-text">vim 使用tip</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#附录"><span class="toc-text">附录</span></a></li></ol>
  </div>
  




<div class="content content-post CENTER">
   <!-- canvas 彩带 -->
<canvas id="evanyou" width="1302" height="678" style="position: fixed;width: 100%;height: 100%;top: 0;left:0;z-index:-1;"></canvas>

<article id="post-Vim使用摘要笔记" class="article article-type-post" itemprop="blogPost">
  <header class="article-header" style="position:relative;">
    <h1 class="post-title">Vim使用摘要笔记</h1>

    <div class="article-meta">
      <span>
        <i class="icon-calendar"></i>
        <span>2016.03.19</span>
      </span>

      
        <span class="article-author">
          <i class="icon-user"></i>
          <span>Poetry</span>
        </span>
      

      
  <span class="article-category">
    <i class="icon-list"></i>
    <a class="article-category-link" href="/categories/工欲善其事必先利其器/">工欲善其事必先利其器</a>
  </span>



      

      
      <i class="fa fa-eye"></i> 
        <span id="busuanzi_container_page_pv">
           &nbsp热度 <span id="busuanzi_value_page_pv">
           <i class="fa fa-spinner fa-spin"></i></span>℃
        </span>
      
      
       
          <span class="post-count">
            <i class="fa fa-file-word-o"></i>&nbsp
            <span>字数统计 2.5k字</span>
          </span>

          <span class="post-count">
            <i class="fa fa-columns"></i>&nbsp
            <span>阅读时长 8分</span>
          </span>
      
      
    </div>

    <i class="iconfont" id="toc-eye" style="display:inline-block;color:#b36619;position:absolute;top:0;right:0;cursor:pointer;
    font-size: 24px;">&#xe61c;</i>

  </header>

  <div class="article-content">
    
      <div id="container">
        <h3 id="插入模式和退出VIM的方法"><a href="#插入模式和退出VIM的方法" class="headerlink" title="插入模式和退出VIM的方法"></a>插入模式和退出VIM的方法</h3><p>VIM 具有 6 种基本模式和 5 种派生模式。<br><a id="more"></a></p>
<blockquote>
<p>基本模式：普通模式、插入模式、可视模式、选择模式、命令行模式和 Ex 模式；</p>
</blockquote>
<blockquote>
<p>派生模式：操作符等待模式、插入普通模式、插入可视模式、插入选择模式和替换模式</p>
</blockquote>
<hr>
<p><img src="http://7xq6al.com1.z0.glb.clouddn.com/vim-1.png" alt="此处输入图片的描述"></p>
<p><img src="http://7xq6al.com1.z0.glb.clouddn.com/vim-2.png" alt="此处输入图片的描述"></p>
<hr>
<h3 id="删除命令、数字的奥义、撤销和恢复命令"><a href="#删除命令、数字的奥义、撤销和恢复命令" class="headerlink" title="删除命令、数字的奥义、撤销和恢复命令"></a>删除命令、数字的奥义、撤销和恢复命令</h3><p><img src="http://7xq6al.com1.z0.glb.clouddn.com/vim-3.png" alt="此处输入图片的描述"></p>
<p><img src="http://7xq6al.com1.z0.glb.clouddn.com/vim-4.png" alt="此处输入图片的描述"></p>
<p><img src="http://7xq6al.com1.z0.glb.clouddn.com/vim-5.png" alt="此处输入图片的描述"></p>
<hr>
<h3 id="粘贴命令、替换命令、替换模式和修改命令"><a href="#粘贴命令、替换命令、替换模式和修改命令" class="headerlink" title="粘贴命令、替换命令、替换模式和修改命令"></a>粘贴命令、替换命令、替换模式和修改命令</h3><ul>
<li><strong>粘贴命令</strong><br>使用 p 命令可以将最后一次删除的内容粘贴到光标之后。（大写的 P 则是粘贴到光标之前）</li>
</ul>
<p><strong>这里需要注意的是：</strong>如果你需要粘贴的是整行为单位，那么 p 命令将在光标的下一行开始粘贴；如果你拷贝的是非整行的局部字符串，那么 p 命令将在光标后开始粘贴。</p>
<ul>
<li><strong>拷贝命令</strong></li>
</ul>
<p>其实我们用的最多的还是拷贝粘贴，VIM 用 y 命令实现拷贝。语法跟删除的 d 命令一样：<code>d motion</code></p>
<p>其中的 motion 同样是用来表示操作范围的指令，即 yy 表示拷贝当前行，<code>3yy</code> 则表示拷贝 3 行；<code>y$</code> 表示从光标所在的位置拷贝到行尾的所有字符；<code>yG</code> 则表示从光标所在行拷贝到文件末尾行的所有字符</p>
<p>拷贝完成之后同样使用 <code>p</code> 命令进行粘贴</p>
<ul>
<li><strong>替换命令</strong></li>
</ul>
<p>VIM 还提供了一个简单的替换命令：r 命令</p>
<p>r 用于替换光标所在的字符，做法是先将光标移动到需要替换的字符处，按一下 r 键，然后输入新的字符。注意，全程无需进入插入模式，也不会进入插入模式</p>
<ul>
<li><strong>替换模式</strong></li>
</ul>
<p>对于需要替换多个字符，更好的方案是直接进入替换模式。按下大写的 R 键，屏幕左下角出现 – REPLACE – 字样，说明你已经处于替换模式。此时输入字符可以连续替换光标及其后边的内容。</p>
<ul>
<li><strong>修改命令</strong></li>
</ul>
<p>修改跟替换是不一样的！<br>修改跟替换是不一样的！</p>
<p>修改会进入插入模式，替换不会进入插入模式！<br>修改会进入插入模式，替换不会进入插入模式！</p>
<p>修改命令我们使用 c 键来启动，格式是：<code>c [number] motion</code></p>
<p><code>motion</code> 依然表示范围，[数字]依然拥有奥义，同样是可选的，加上数字表示重复执行多次 motion 范围…</p>
<p><img src="http://7xq6al.com1.z0.glb.clouddn.com/vim-6.png" alt="此处输入图片的描述"></p>
<p>事实上，<strong>修改 == 删除 + 进入插入模式</strong></p>
<hr>
<h3 id="文件信息、跳转、定位括号和缩进"><a href="#文件信息、跳转、定位括号和缩进" class="headerlink" title="文件信息、跳转、定位括号和缩进"></a>文件信息、跳转、定位括号和缩进</h3><p>有时候，你可能需要知道当前的文件信息，比如文件名，文件状态，文件的总行数，以及光标所在的相对位置</p>
<p>快捷键 <code>ctrl + g</code> 可以解决你的需求：</p>
<p><img src="http://xxx.fishc.com/forum/201510/29/232631xzmv2mjpv9ii4vao.png" alt="此处输入图片的描述"></p>
<ul>
<li><strong>跳转</strong></li>
</ul>
<p>在 VIM 有两种方式可以将光标跳转到指定的位置：</p>
<ul>
<li>行号 + G</li>
<li>行号</li>
</ul>
<p>比如将光标跳转到第 333 行的位置，你就输入数字 333，再输入大写字母 G 即可见证奇迹；或者输入冒号（:）进入命令行模式，再输入数字 333，最后回车，也可以跳转到目的地</p>
<p>如果单独输入 G 键（前边没有输入数字），那么光标是直接去到文件的最后一行；如果输入两个小写 g，即 <code>gg</code>，则将光标跳转到文件的第一行。</p>
<ul>
<li><strong>定位括号</strong></li>
</ul>
<p>VIM 有个按键可以帮你快速定位到另一半括号，就是 % 键。将光标移动到 <code>()，[]，{}</code>，中的任何一半括号上，按下 <code>%</code> 键，便可看到此时光标已经跳转到另外一半的括号上了</p>
<ul>
<li><strong>缩进</strong></li>
</ul>
<p>在编写代码的时候我们经常需要对代码进行缩进，VIM 可以使用尖括号（<code>&amp;lt;</code> 或 <code>&amp;gt;</code>）来控制缩进，我们常用的就是两个同方向的尖括号表示将光标所在的语句进行缩进和反缩进操作。很明显 <code>&amp;gt;&amp;gt;</code> 表示缩进，而 <code>&amp;lt;&amp;lt;</code> 则表示反缩进</p>
<p>不过行数一多……到底要缩进多少行就成了一个问题……这时，你可以按一下 <code>v</code> 进入可视模式（左下角出现 <code>-- VISUAL --</code> 字样），然后通过 <code>h、j、k、l</code> 或 其他 <code>motion</code> 来移动你的光标，此时光标所到之处必被一道亮光所包围（表示被选中），选择好需要缩进的目标后，只需按一下 <code>&amp;gt;</code> 即可完成任务</p>
<p><img src="http://xxx.fishc.com/forum/201511/06/162556ihjb5obhtgf5s6jm.png" alt="此处输入图片的描述"></p>
<hr>
<h3 id="搜索命令和替换命令"><a href="#搜索命令和替换命令" class="headerlink" title="搜索命令和替换命令"></a>搜索命令和替换命令</h3><ul>
<li><strong>搜索命令</strong></li>
</ul>
<p><img src="http://7xq6al.com1.z0.glb.clouddn.com/vim-7.png" alt="此处输入图片的描述"></p>
<p>最后提个醒：在搜索命令中，<code>.、*、[、]、^、%、/、?、~</code> 和 <code>$</code> 这 10 个字符有着特殊意义，所以在使用这些字符的时候要在前面加上一个反斜杠<code>（\）</code>，比如你要搜索问号，则输入 <code>/\?</code></p>
<ul>
<li><strong>替换命令</strong></li>
</ul>
<p>搜索在很多情况下都是为了替换</p>
<p>通过搜索功能，我们将光标定位到目标位置，如果你确定这个目标是可恶的，需要被替换的，你可以输入 <code>:s/old/new</code>，这样即可将光标所在行的第一个 old 替换为 new；你如果输入的是 <code>:s/old/new/g</code>，则表示将光标所在行的所有 old 替换为 new。</p>
<p>输入 : <code>%s/old/new/g</code> 表示替换整个文件中每个匹配的字符串<br>输入 : <code>%s/old/new/gc</code> 替换提示信息<br>输入 : <code>5,13s/old/new/g</code> 替换第 5 行到第 13 行之间的所有 XX</p>
<h3 id="执行shell命令、文件另存为、合并文件和打开多个文件"><a href="#执行shell命令、文件另存为、合并文件和打开多个文件" class="headerlink" title="执行shell命令、文件另存为、合并文件和打开多个文件"></a>执行shell命令、文件另存为、合并文件和打开多个文件</h3><ul>
<li><strong>执行shell命令</strong></li>
</ul>
<p>想知道当前 / 下边有哪些目录和文件，在 VIM 中你可以输入 <code>:!ls</code></p>
<p>在输入冒号（:）进入命令行模式，输入感叹号（<code>!</code>），在其后便可以加上 <code>shell</code> 命令。此后 VIM 将临时跳转回 shell，并执行命令。再次按下 Enter 键回到 VIM</p>
<ul>
<li><strong>文件另存为</strong></li>
</ul>
<p>输入 <code>:w 新文件名</code>   文件另存为</p>
<p>如：输入 <code>:w test2</code> 该命令会以 test2 为文件名拷贝保存整个 test 文件</p>
<ul>
<li><strong>局部内容另存为</strong></li>
</ul>
<p>言下之意就是，VIM 可以将文件中的局部文本另存为一个新的文件</p>
<p>这就需要你进入一种新的模式，叫：<code>可视模式</code></p>
<p>在普通模式中按下 <code>V</code> 键即进入可视模式，进入后左下角显示 <code>VISUAL</code></p>
<p>此时光标的位置开始为选中状态，你可以通过任何移动或范围的按键来移动光标，光标所到之处皆为选中状态（<code>h、j、k、l</code> 移动光标，$ 去到行尾，0 去到行首……）：</p>
<p>选好范围之后的操作就跟“文件另存为”一样了；<code>按下冒号（:）</code>屏幕左下方出现 :<code>&#39;&amp;lt;,&#39;&amp;gt;</code>现在请输入 <code>w test2</code>；表示新建一个 test2 文件，并将选中的内容单独存放进去。</p>
<p>这里有个问题，如果路径中已经存在 test2 文件，那么 VIM 会提醒你需要加感叹号（!）才能强制覆盖文件。即输入 <code>w! test2</code></p>
<ul>
<li><strong>合并文件</strong></li>
</ul>
<p>所谓合并文件，便是在 VIM 打开的一个文件中读取并置入另一个文件</p>
<p>只需要输入冒号（:）进入命令行模式，然后输入 <code>r</code> 文件名</p>
<p>即可将指定文件的内容读取并置入到光标的下一行中</p>
<ul>
<li><strong>打开多个文件</strong></li>
</ul>
<p>VIM 还可以同时打开多个文件，并且允许你通过水平或垂直的方式并排它们</p>
<p>VIM 使用 <code>–o 或 –O</code> 选项打开多个文件，其中 <code>–o</code> 表示垂直并排，<code>-O</code> 表示水平并排；例如 <code>vim -o lesson4 lesson5 lesson6</code></p>
<p>打开后默认光标是落在第一个文件中的，此时之前学过的所有命令都可以上，不过仅限于第一个文件。那如何将焦点（光标）切换到另一个文件中呢？很简单，使用 <code>ctrl + w + w</code> 将光标切换到下一个文件；或者使用 ctrl + w + 方向（方向键或 h、j、k、l）</p>
<p>退出文件的话可以使用原来的 <code>q、q!、wq</code> 或者 <code>ZZ（shirt + z + z）</code></p>
<p>退出多个文件：命令的后边加上小写 <code>a</code>，则表示退出动作是针对所有的<code>（ALL）：qa、qa!、wqa</code></p>
<hr>
<h3 id="其他总结"><a href="#其他总结" class="headerlink" title="其他总结"></a>其他总结</h3><ul>
<li><strong>【vim窗口管理】</strong></li>
</ul>
<ul>
<li><p>打开<strong>NerdTRee</strong>(<code>：NER--&gt;tab</code>)</p>
</li>
<li><p>多屏幕移动光标左侧 <code>ctrl+w+h</code>  右侧 <code>ctrl+w+l</code>  在目录结构打开文件 i</p>
</li>
<li><p><code>0</code> 展开目录结构</p>
</li>
</ul>
<p>自动补全：ctrl+P（基于单词）</p>
<ul>
<li><p><strong>【配置VIM】</strong></p>
<ul>
<li><p>临时的配置  <code>：set</code> 或者 <code>：set all</code></p>
</li>
<li><p>永久的配置  <code>~/.vimrcor ~/.exrc</code></p>
</li>
</ul>
</li>
<li><p>一些通用的配置  ：</p>
<ul>
<li>:set number  </li>
<li>:set autoindent  </li>
<li>:set textwidth=65(vim only)</li>
<li>:set wrapmargin=15</li>
<li>:set ignorecase</li>
</ul>
</li>
</ul>
<hr>
<h3 id="vim-使用tip"><a href="#vim-使用tip" class="headerlink" title="vim 使用tip"></a>vim 使用tip</h3><ul>
<li><strong>编写python程序</strong></li>
</ul>
<p>自动插入头信息：</p>
<pre><code>#!/usr/bin/env python
# coding=utf-8
</code></pre><p>输入<code>.</code>或按<code>TAB</code>键会触发代码补全功能<br><code>:w</code>保存代码之后会自动检查代码错误与规范<br>按F6可以按pep8格式对代码格式优化<br>按<code>F5</code>可以一键执行代码<br>多窗口操作</p>
<p>使用<code>:sp + 文件名</code> 可以水平分割窗口<br>使用<code>:vs + 文件名</code> 可以垂直分割窗口<br>使用<code>Ctrl + w</code> 可以快速在窗口间切换</p>
<ul>
<li><strong>编写markdown文件</strong></li>
</ul>
<p>编写markdown文件(*.md)的时候，在<code>normal</code>模式下按 <code>md</code> 即可在当前目录下生成相应的<code>html</code>文件</p>
<p>生成之后还是在<code>normal</code>模式按<code>fi</code>可以使用firefox打开相应的html文件预览<br>当然也可以使用万能的<code>F5键</code>来一键转换并打开预览<br>如果打开过程中屏幕出现一些混乱信息，可以按<code>Ctrl + l</code>来恢复<br>快速注释</p>
<hr>
<h3 id="附录"><a href="#附录" class="headerlink" title="附录"></a>附录</h3><ul>
<li><strong>vim配置文件和插件</strong></li>
</ul>
<p>下载地址：<a href="https://github.com/ma6174/vim" target="_blank" rel="noopener">超强vim配置文件</a></p>
<p><strong>运行截图</strong></p>
<p><img src="https://github.com/ma6174/vim/raw/master/screenshot.png" alt="此处输入图片的描述"></p>
<hr>
<ul>
<li><strong>vim键位图–重要</strong></li>
</ul>
<p><strong>入门版</strong></p>
<p><img src="http://7xq6al.com1.z0.glb.clouddn.com/%E5%85%A5%E9%97%A8%E7%89%88--vim.png" alt="此处输入图片的描述"></p>
<hr>
<p><strong>经典版【推荐】</strong></p>
<p><img src="http://7xq6al.com1.z0.glb.clouddn.com/%E7%BB%8F%E5%85%B8%E7%89%88--vim.gif" alt="此处输入图片的描述"></p>
<hr>
<p><strong>进阶版</strong></p>
<p><img src="http://7xq6al.com1.z0.glb.clouddn.com/%E8%BF%9B%E9%98%B6%E7%89%88--vim.png" alt="此处输入图片的描述"></p>
<hr>
<p><strong>增强版</strong></p>
<p><img src="http://7xq6al.com1.z0.glb.clouddn.com/%E5%A2%9E%E5%BC%BA%E7%89%88--vim.png" alt="此处输入图片的描述"></p>

      </div>
    
  </div>

</article>

<button class="assist-btn2 circle" id="assist_btn2" title="点亮屏幕" style="left: 27px; top: 152px;">
  <i class="iconfont" style="display:inline-block;color:red;width:20px;height:20px;">&#xe61d;</i>
</button>
<button class="assist-btn1 circle" id="assist_btn1" title="关闭屏幕亮度" style="left: 27px; top: 152px;">
  <i class="iconfont toc-title" style="display:inline-block;color:red;width:20px;height:20px;">&#xe61d;</i>
</button>


<script src="//cdn.bootcss.com/jquery/3.1.1/jquery.min.js"></script>	

<script src="https://my.openwrite.cn/js/readmore.js" type="text/javascript"></script>
<script>
  const btw = new BTWPlugin();
  btw.init({
    id: "container",
    blogId: "22699-1592137983091-414",
    name: "前端进阶之旅",
    qrcode: "https://poetries1.gitee.io/img-repo/2020/06/qrcode.jpg",
    keyword: "3a3b3c",
  });
</script>

<script type="text/javascript">

// white theme
var body = {color: "#555", background: "#000"};
var a_tag = {color: "#222"};
var header = { background: "#222"};
var logo_line_i = {background: "#222"};
// var post_code = {background: "#eee", color: "#222"};

function switch_theme() {
 $("body").css(body);
 $("a:not('.links-of-author-item a, .site-state-item a, .site-state-posts a, .feed-link a, .motion-element a, .post-tags a, .show-commit-cls a, #donate_board a')").css(a_tag);
 $(".header, .footer").css(header);
 $(".logo-line-before i, .logo-line-after i").css(logo_line_i);
 //$(".post code").css(post_code);
 $("#idhyt-surprise-ball #idhyt-surprise-ball-animation .drag").css(a_tag);
 $(".post-title-link, .posts-expand .post-meta, .post-comments-count, .disqus-comment-count, .post-category a, .post-nav-next a, .post-nav-item a").css(a_tag);
 
 // $("code").css({color: '#c5c8c6', background: '#1d1f21'});
 //$("#assist_btn1").hide(1500);
}

$(function () {
$("#assist_btn2").css("display","none");
 $("#assist_btn1").click(function() {
     switch_theme();
$("div#toc.toc-article").css({
 "background":"#eaeaea",
 "opacity":1
});
$(".toc-article ol").show();
$("#toc.toc-article .toc-title").css("color","#a98602");
$("#assist_btn1").css("display","none");
$("#assist_btn2").css("display","block");
 });
$("#assist_btn2").click(function() {
$("#assist_btn2").css("display","none");
$("#assist_btn1").css("display","block");
$("body").css("background","url(http://www.miaov.com/static/ie/images/news/bg.png)")
     $(".header, .footer").css("background","url(http://www.miaov.com/static/ie/images/news/bg.png)")
$(".toc-article ol").toggle(1000);
 });
});


//背景随机

var Y, O, E, L, B, C, T, z, N, S, A, I;
!function() {
var e = function() {
for (O.clearRect(0, 0, L, B), T = [{
x: 0,
y: .7 * B + C
}, {
x: 0,
y: .7 * B - C
}]; T[1].x < L + C;) t(T[0], T[1])
}, t = function(e, t) {
O.beginPath(), O.moveTo(e.x, e.y), O.lineTo(t.x, t.y);
var n = t.x + (2 * I() - .25) * C,
 r = a(t.y);
O.lineTo(n, r), O.closePath(), N -= S / -50, O.fillStyle = "#" + (127 * A(N) + 128 << 16 | 127 * A(N + S / 3) + 128 << 8 | 127 * A(N + S / 3 * 2) + 128).toString(16), O.fill(), T[0] = T[1], T[1] = {
 x: n,
 y: r
}
}, a = function n(e) {
var t = e + (2 * I() - 1.1) * C;
return t > B || t < 0 ? n(e) : t
};
Y = document.getElementById("evanyou"), O = Y.getContext("2d"), E = window.devicePixelRatio || 1, L = window.innerWidth, B = window.innerHeight, C = 90, z = Math, N = 0, S = 2 * z.PI, A = z.cos, I = z.random, Y.width = L * E, Y.height = B * E, O.scale(E, E), O.globalAlpha = .6, document.onclick = e, document.ontouchstart = e, e()
}()

   
$("#toc-eye").click(function(){
$("#toc.toc-article").toggle(1000);
});

</script>


   
  <div class="text-center donation">
    <div class="inner-donation">
      <span class="btn-donation">支持一下</span>
      <div class="donation-body">
        <div class="tip text-center">扫一扫，支持poetries</div>
        <ul>
        
          <li class="item">
            
              <span>微信扫一扫</span>
            
            <img src="/images/weixin.jpg" alt="">
          </li>
        
          <li class="item">
            
              <span>支付宝扫一扫</span>
            
            <img src="/images/zhifubao.jpg" alt="">
          </li>
        
        </ul>
      </div>
    </div>
  </div>


   
  <div class="box-prev-next clearfix">
    <a class="show pull-left" href="/2016/03/16/CSS块级元素和行内元素/">
        <i class="icon icon-angle-left"></i>
    </a>
    <a class="show pull-right" href="/2016/03/21/简明-Vim-练级攻略/">
        <i class="icon icon-angle-right"></i>
    </a>
  </div>




</div>


  <a id="backTop" class="back-top">
    <i class="icon-angle-up"></i>
  </a>




  <div class="modal" id="modal">
  <span id="cover" class="cover hide"></span>
  <div id="modal-dialog" class="modal-dialog hide-dialog">
    <div class="modal-header">
      <span id="close" class="btn-close">关闭</span>
    </div>
    <hr>
    <div class="modal-body">
      <ul class="list-toolbox">
        
          <li class="item-toolbox">
            <a
              class="CIRCLE"
              href="/archives/"
              rel="noopener noreferrer"
              target="_self"
              >
              博客
            </a>
          </li>
        
          <li class="item-toolbox">
            <a
              class="CIRCLE"
              href="/categories/"
              rel="noopener noreferrer"
              target="_self"
              >
              分类
            </a>
          </li>
        
          <li class="item-toolbox">
            <a
              class="CIRCLE"
              href="/tags/"
              rel="noopener noreferrer"
              target="_self"
              >
              标签
            </a>
          </li>
        
          <li class="item-toolbox">
            <a
              class="CIRCLE"
              href="/search/"
              rel="noopener noreferrer"
              target="_self"
              >
              搜索
            </a>
          </li>
        
          <li class="item-toolbox">
            <a
              class="CIRCLE"
              href="/link/"
              rel="noopener noreferrer"
              target="_self"
              >
              友链
            </a>
          </li>
        
          <li class="item-toolbox">
            <a
              class="CIRCLE"
              href="/about/"
              rel="noopener noreferrer"
              target="_self"
              >
              关于
            </a>
          </li>
        
      </ul>

    </div>
  </div>
</div>



  
      <div class="fexo-comments comments-post">
    

    

    
    

    

    
    

    

<!-- Gitalk评论插件通用代码 -->
<div id="gitalk-container"></div>

<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/gitalk@1/dist/gitalk.css">
<script src="https://cdn.jsdelivr.net/npm/gitalk@1/dist/gitalk.min.js"></script>
<script>
const gitalk = new Gitalk({
  clientID: '5567a2c4abb858009d96',
  clientSecret: 'b9039ec056cf5c2346b3cdb63308a28c163f91e5',
  repo: 'poetries.github.io',
  owner: 'poetries',
  // 在这里设置一下截取前50个字符串, 这是因为 github 对 label 的长度有了要求, 如果超过
  // 50个字符串则会报错.
  // id: location.pathname.split('/').pop().substring(0, 49),
  id: location.pathname,
  admin: ['poetries'],
  // facebook-like distraction free mode
  distractionFreeMode: false
})
gitalk.render('gitalk-container')
</script>
<!-- Gitalk代码结束 -->



  </div>

  

  <script type="text/javascript">
  function loadScript(url, callback) {
    var script = document.createElement('script')
    script.type = 'text/javascript';

    if (script.readyState) { //IE
      script.onreadystatechange = function() {
        if (script.readyState == 'loaded' ||
          script.readyState == 'complete') {
          script.onreadystatechange = null;
          callback();
        }
      };
    } else { //Others
      script.onload = function() {
        callback();
      };
    }

    script.src = url;
    document.getElementsByTagName('head')[0].appendChild(script);
  }

  window.onload = function() {
    loadScript('/js/bundle.js?235683', function() {
      // load success
    });
  }
</script>


  <!-- 页面点击小红心 -->
  <script type="text/javascript" src="/js/clicklove.js"></script>
 
  
</body>
</html>
